# Projeto de Sistemas Digitais

- Arthur Alexandre Nascimento
- Eduardo Vinicius Betim
- Fábio Pereira dos Santos
- Rafael Francisco Réus

### Algoritmo de divisão

```
Algoritmo divseq
  1 Início{
       A \leftarrow \text{ent1}; B \leftarrow \text{ent2}; \text{cont} \leftarrow 0; \text{pronto} \leftarrow 0;
       if B!=0 then {
         while A >= B \{
            cont \leftarrow cont + 1;
        A \leftarrow A - B;
         quoc \leftarrow cont; resto \leftarrow A;
 8
         pronto\leftarrow 1; erro\leftarrow 0;
 9
10
       else
11
         pronto\leftarrow1; erro\leftarrow1;
12 }
```

#### **FSMD**



### Bloco Operativo



#### State Machine Viewer



### RTL Viewer - Topo



#### RTL Viewer - BO



#### RTL Viewer - BC



### Comparação N = 4 e N = 8

| Flow Status                        | Successful - Wed Nov 25 16:51:03 2020           |
|------------------------------------|-------------------------------------------------|
| Quartus II 64-Bit Version          | 13.0.1 Build 232 06/12/2013 SP 1 SJ Web Edition |
| Revision Name                      | divisor                                         |
| Top-level Entity Name              | divisor                                         |
| Family                             | Cyclone II                                      |
| Device                             | EP2C35F672C6                                    |
| Timing Models                      | Final                                           |
| Total logic elements               | 33 / 33,216 ( < 1 % )                           |
| Total combinational functions      | 21 / 33,216 ( < 1 % )                           |
| Dedicated logic registers          | 26 / 33,216 ( < 1 %)                            |
| Total registers                    | 26                                              |
| Total pins                         | 21 / 475 ( 4 % )                                |
| Total virtual pins                 | 0                                               |
| Total memory bits                  | 0 / 483,840 (0 %)                               |
| Embedded Multiplier 9-bit elements | 0 / 70 (0 %)                                    |
| Total PLLs                         | 0/4(0%)                                         |
|                                    |                                                 |

| Flow Status                        | Successful - Wed Nov 25 16:55:59 2020           |
|------------------------------------|-------------------------------------------------|
| Quartus II 64-Bit Version          | 13.0.1 Build 232 06/12/2013 SP 1 SJ Web Edition |
| Revision Name                      | divisor                                         |
| Top-level Entity Name              | divisor                                         |
| Family                             | Cyclone II                                      |
| Device                             | EP2C35F672C6                                    |
| Timing Models                      | Final                                           |
| Total logic elements               | 50 / 33,216 ( < 1 % )                           |
| Total combinational functions      | 34 / 33,216 ( < 1 %)                            |
| Dedicated logic registers          | 46 / 33,216 ( < 1 % )                           |
| Total registers                    | 46                                              |
| Total pins                         | 37 / 475 (8 %)                                  |
| Total virtual pins                 | 0                                               |
| Total memory bits                  | 0 / 483,840 ( 0 % )                             |
| Embedded Multiplier 9-bit elements | 0 / 70 (0 %)                                    |
| Total PLLs                         | 0/4(0%)                                         |
|                                    |                                                 |

### Comparação N = 4 e N = 8

|   | Data Port  | Clock Port | Rise  | Fall  | Clock Edge | Clock Reference |
|---|------------|------------|-------|-------|------------|-----------------|
| 1 | erro       | clk        | 6.750 | 6.750 | Rise       | clk             |
| 2 | pronto     | dk         | 7.227 | 7.227 | Rise       | dk              |
| 3 | ∨ quoc[*]  | clk        | 6.392 | 6.392 | Rise       | dk              |
| 1 | quoc[0]    | dk         | 6.392 | 6.392 | Rise       | dk              |
| 2 | quoc[1]    | clk        | 6.585 | 6.585 | Rise       | dk              |
| 3 | quoc[2]    | dk         | 6.603 | 6.603 | Rise       | dk              |
| 4 | quoc[3]    | clk        | 6.600 | 6.600 | Rise       | dk              |
| 4 | ✓ resto[*] | clk        | 6.342 | 6.342 | Rise       | dk              |
| 1 | resto[0]   | clk        | 6.402 | 6.402 | Rise       | dk              |
| 2 | resto[1]   | dk         | 6.342 | 6.342 | Rise       | dk              |
| 3 | resto[2]   | dk         | 6.595 | 6.595 | Rise       | dk              |
| 4 | resto[3]   | dk         | 6.610 | 6.610 | Rise       | clk             |

|   | Data Port  | Clock Port | Rise  | Fall  | Clock Edge | Clock Reference |
|---|------------|------------|-------|-------|------------|-----------------|
| 1 | erro       | clk        | 6.613 | 6.613 | Rise       | clk             |
| 2 | pronto     | clk        | 7.186 | 7.186 | Rise       | dk              |
| 3 | ✓ quoc[*]  | clk        | 6.270 | 6.270 | Rise       | dk              |
| 1 | quoc[0]    | clk        | 6.370 | 6.370 | Rise       | dk              |
| 2 | quoc[1]    | clk        | 6.358 | 6.358 | Rise       | dk              |
| 3 | quoc[2]    | clk        | 6.270 | 6.270 | Rise       | dk              |
| 4 | quoc[3]    | clk        | 6.411 | 6.411 | Rise       | dk              |
| 5 | quoc[4]    | clk        | 6.523 | 6.523 | Rise       | dk              |
| 6 | quoc[5]    | clk        | 6.528 | 6.528 | Rise       | dk              |
| 7 | quoc[6]    | clk        | 6.357 | 6.357 | Rise       | dk              |
| 8 | quoc[7]    | clk        | 6.396 | 6.396 | Rise       | dk              |
| 4 | ✓ resto[*] | clk        | 6.333 | 6.333 | Rise       | dk              |
| 1 | resto[0]   | clk        | 6.370 | 6.370 | Rise       | dk              |
| 2 | resto[1]   | clk        | 6.333 | 6.333 | Rise       | clk             |
| 3 | resto[2]   | clk        | 6.838 | 6.838 | Rise       | clk             |
| 4 | resto[3]   | clk        | 6.351 | 6.351 | Rise       | clk             |
| 5 | resto[4]   | clk        | 6.582 | 6.582 | Rise       | dk              |
| 6 | resto[5]   | clk        | 6.550 | 6.550 | Rise       | dk              |
| 7 | resto[6]   | clk        | 6.840 | 6.840 | Rise       | clk             |
| 8 | resto[7]   | clk        | 6.370 | 6.370 | Rise       | clk             |

### Simulação 12 / 3 - 4 bits



### Simulação 12 / 5 - 4 bits



#### Simulação 12 / 3 - 8 Bits



#### Conclusão

 Aumento de aprox. 50% na quantidade de elementos lógicos comparando 4 e 8 bits.

O tempo mínimo de clock até a saída diminui levemente na versão com 8 bits.

## Fim